<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>2341. 数组能形成多少数对</title>
  </head>
  <body>
    <script>
      //     给你一个下标从 0 开始的整数数组 nums 。在一步操作中，你可以执行以下步骤：

      // 从 nums 选出 两个 相等的 整数
      // 从 nums 中移除这两个整数，形成一个 数对
      // 请你在 nums 上多次执行此操作直到无法继续执行。

      // 返回一个下标从 0 开始、长度为 2 的整数数组 answer 作为答案，其中 answer[0] 是形成的数对数目，answer[1] 是对 nums 尽可能执行上述操作后剩下的整数数目。

      //

      // 示例 1：

      // 输入：nums = [1,3,2,1,3,2,2]
      // 输出：[3,1]
      // 解释：
      // nums[0] 和 nums[3] 形成一个数对，并从 nums 中移除，nums = [3,2,3,2,2] 。
      // nums[0] 和 nums[2] 形成一个数对，并从 nums 中移除，nums = [2,2,2] 。
      // nums[0] 和 nums[1] 形成一个数对，并从 nums 中移除，nums = [2] 。
      // 无法形成更多数对。总共形成 3 个数对，nums 中剩下 1 个数字。
      // 示例 2：

      // 输入：nums = [1,1]
      // 输出：[1,0]
      // 解释：nums[0] 和 nums[1] 形成一个数对，并从 nums 中移除，nums = [] 。
      // 无法形成更多数对。总共形成 1 个数对，nums 中剩下 0 个数字。
      // 示例 3：

      // 输入：nums = [0]
      // 输出：[0,1]
      // 解释：无法形成数对，nums 中剩下 1 个数字。
      //

      // 提示：

      // 1 <= nums.length <= 100
      // 0 <= nums[i] <= 100

      // 来源：力扣（LeetCode）
      // 链接：https://leetcode.cn/problems/maximum-number-of-pairs-in-array
      // 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
      /**
       * @param {number[]} nums
       * @return {number[]}
       */
      var numberOfPairs = function (nums) {
        if (nums.length === 1) {
          return [0, 1]
        }
        nums.sort()
        let num = nums[0]
        let sus = 0
        let lonely = 0
        // debugger
        for (let i = 1; i < nums.length; i++) {
          if (nums[i] === num) {
            sus++
            num = nums[i + 1]
            i++
          } else {
            lonely++
            num = nums[i]
          }
        }
        if (num) {
          lonely++
        }
        return [sus, lonely]
      }
      console.log(numberOfPairs([1, 2, 3, 4, 5]))
    </script>
  </body>
</html>
